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DATA STORAGE SYSTEM INTERFACE 

This invention relates to a method of operating a computer system to provide a user 
interface to a data storage system and to a computer system for providing a user 
5 interface to a data storage system. 

A database management system (DBMS) controls the organisation, storage, retrieval, 
security and integrity of data in a database. Many organisations today use multiple, 
distributed, heterogeneous databases to support their processes (e.g. sales, marketing, 

10 purchases, employee databases) supplied by a variety of vendors (e.g. IBM, Oracle, 
Sybase). Each database may be using different data models including relational, object- 
relational and object oriented ones. Additionally, each database may provide different 
mechanisms (interfaces) for accessing the data. Furthermore, data of interest may be 
distributed among more than one database. Further complicating issues stemming from 

1 5 the use of multiple and heterogeneous databases (see Sheth et al.. Federated Database 
Systems for Managing Distributed, Heterogeneous, and Autonomous Databases, ACM 
Computing Surveys 22(3), pp 183-236, 1990), render users unable easily to obtain and 
collate the information they require in a timely fashion. 

20 The management of such multiple, distributed databases draws upon the area of 
database integration. In this field, there are two approaches to this integration. These 
are Mediators and Federated Database Management Systems (FDBMS). 

Mediators are components that explicitly implement the integration of component 
25 databases. Their job is to store and retrieve data by translating the client requests and 
results between a high-level data model and the native data model of each data source. 
Example systems that use mediators are TSIMMIS (see S. Chawatiie et ai.. The 
TSIMMIS Project: Integration of Heterogeneous Information Sources, Proceedings of 
IPSJ Conference, pp. 7-18, Tokyo, Japan, October 1994), DISCO (see A. Tomasic et 
30 al.. Scaling Heterogeneous Databases and the Design of Disco, Proceedings of the 
International Conference on Distributed Computer Systems, 1996) and Garlic (see M.J. 
Carey et al.. Towards Heterogeneous Multimedia Information Systems: The Garlic 
Approach, Proceedings of the Fifth International Worl<shop on Research Issues in Data 
Engineering (RIDE): Distributed Object Management, 1995). 
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In the FDBMS approach, data schemata of the component databases undergo several 
stages of transformation until a common integrated schema is produced. This is 
represented in a semantically rich data model, i.e. one that can describe all the specific 
5 features of the individual models adopted by each component source. This approach is 
applied by database vendors who, apart from their main commercial databases, develop 
so-called database gateways, i.e. solutions that provide transparent access to content 
stored in other vendors' databases. For instance, Sybase Inc. have developed the 
^Adaptive Server®" that accesses data stored in Sybase as well as in DB2 (by IBM) and 
10 Oracle. Similar capabilities are offered by 'ORACLE 8i% the 'Informix Enterprise 
Gateway' and IBM's 'DB2 DataJoiner'. Additional examples may be companies that 
solely develop data integration solutions such as Cohere with their 'Content Integration 
System' and Data Integration Inc with 'InterViso'. 

1 5 However, in these approaches there are two major deficiencies. First is the inflexibility 
to change. If a need for change occurs (including the addition of new 
databases/datastores to the system, the removal of existing ones or changes to the 
required behaviour of the system), the system must be statically reconfigured before the 
changes take effect. Such a reconfiguration process may involve the substitution of a 

20 new software part for an old software part, the change of configuration parameters of 
the system and the restart of the system. Second, there is a requirement in these 
approaches that the target database/datastore be identified in the request to store data 
or query data. Where mediators are used this requirement manifests itself as the need 
to select the particular mediator for handling the request, since each mediator only 

25 integrates/involves certain databases. Similarly in the FDMBS approach, the query or 
storage request should explicitly identify the databases that are to be targeted in the 
data handling process. 

An interface that allows flexible management of data in a distributed environment of 
30 heterogeneous data storage systems is therefore required. 

According to a first aspect of the present invention there is provided a method of 
operating a computer system to provide a user interface to a data storage system, said 
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computer system including a rule store storing one or more rules, said method 
comprising the steps: 

providing a user interface to said rule store enabling user configuration of said 
rule store with one or more rules, each rule including information relating to a handler 
5 program, said handler program being associated with one or more user requirements and 
being operable to interact with said data storage system in accordance with said user 
requirements; 

receiving a request detailing one or more user requirements; 
responsive to receipt of said request: 
10 a) searching said rule store for a rule associating said one or more 

user requirements of said received request with a handler program; 

b) running said handler program to interact with said data storage 
system. 

15 By providing a user interface to a rule store of a computer system, said user interface 
being operable to configure said rule store with one or more rules, each rule including 
information relating to a handler program, said handler program being associated with 
one or more user requirements and being operable to interact with a data storage 
system in accordance with said user requirements, and in response to receiving a 

20 request detailing one or more user requirements, searching the rule store for a rule 
associating said one or more user requirements of the received request with a handler 
program and running the handler, a customisable and extensible computer system 
operable to provide a user interface to a data storage system is provided. It should be 
noted that the term client can refer to a human user or a computer/workstation. 

25 

The computer system is customisable in that the user Interface to the rule store enables 
a user to configure the rule store with rules that are interpretable by the computer 
system and which reflect the user's requirements. This customisability is in addition to 
being able to configure the rule store with rules that drive the internal behaviour of the 
30 computer system and aim at resolving system management issues such as data 
consistency and data integrity. 

The computer system is extensible in that the functionality of the computer system can 
be easily extended - the user has to provide the computer system with sufficient 
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information to find and execute a new handler program aimed at meeting the user's new 
requirements. This can be done by using the user Interface to the rule store to 
configure the rule store with a new rule which includes the information relating to the 
new handler program. 

5 

In one embodiment the information relating to a handler program included in each rule 
comprises the name and the location of the handler program whilst in other 
embodiments the information relating to a handler program comprises the handler 
program itself. This embodiment is advantageous since the handler program can be 
10 deployed at the same time as the rule in which it is included. 

In one embodiment said rule store user interface provision step comprises storing a rule 
associating predetermined user requirements with a handler program executable to 
interact with said rule store to introduce a further rule contained within said request into 
1 5 said rule store. In an alternative embodiment said further rule replaces an existing rule. 
In a further embodiment the request comprises a request to store a handler program. In 
another embodiment the rules are designated with a time after which the rules should 
no longer be applied. In an additional embodiment the request contains a rule 
associating a handler program with the user requirements of said received request. 

20 

In these ways, new handler programs and new rules can be pre-configured when the 
system is deployed, introduced at run time or a combination of both allowing 
customisability and dynamic adjustability to data management requirements. Handler 
programs need not be permanently loaded so those that are not being used make no 
25 demand on computing resources. 

In other embodiments the data storage system comprises a plurality of databases 
possibly of a different format. The embodiments describe a flexible and scalable system 
where new data storage systems can be added while others can be removed according 
30 to requirements and availability simply by loading a relevant rule and/or handler program. 
The embodiments allow for the utilisation of the data storage system technology that 
gives the best performance for a particular data structure and usage pattern. 
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According to a second aspect of the present invention there is provided a computer 
system operable to provide a user interface to a data storage system, said computer 
system comprising: 

a data storage system; 
5 a rule store; 

a user interface to said rule store operable to enable a user to configure said 
rule store with one or more rules, wherein each rule includes information relating to a 
handler program, said handler program being associated with one or more user 
requirements and being operable to interact with said data storage system in accordance 
1 0 with said user requirements; 

request receiving means arranged in operation to receive a request detailing one 
or more user requirements; 

rule store searching means operable to search said rule store for a rule 
associating said one or more user requirements of said received request with a handler 
1 5 program; 

handler program running means operable to run said handler program to interact 
with said data storage system. 

According to a third aspect of the present invention there is a digital data carrier 
20 carrying a program of instructions executable by processing apparatus to perform the 
method steps as set out in the first aspect of the present invention. 

According to a fourth aspect of the present invention there is provided a method of 
operating a computer system to provide a user interface to a data storage system, said 
25 computer system including a rule store storing one or more rules, each rule associating a 
handler program with one or more request characteristics, said method comprising: 

providing a user interface to said rule store enabling the modification of said rules 
in said rule store; 

receiving a request having one or more request characteristics; 
30 responsive to the receipt of said request: 

a) finding a rule in said rule store associating a handler program with 
the one or more characteristics of said received request; and 

b) running said handler program to interact with said data storage 
system. 
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According to a fifth aspect of the present invention there is provided a A computer 
system for providing a user interface to a data storage system said computer system 
comprising: 
5 a data storage system; 

storing means arranged in operation to store one or more rules, each rule 
associating a handler program with one or more request characteristics; 

means arranged in operation to provide a user interface to said rule store 
enabling the modification of said rules in said rule store; 
10 receiving means arranged in operation to receive a request having one or more 

request characteristics: 

finding means arranged in operation to find a rule in said rule store associating a 
handler program with the one or more characteristics of said received request; and 

running means arranged in operation to run said handler program to interact with 
15 said data storage system. 

Embodiments of the present invention will now be described, by way of example only, 
with reference to the accompanying drawings, wherein like reference numbers refer to 
like parts, and in which: 

20 

Figure 1 illustrates the overall structure of a policy according to a first embodiment of 
the present invention; 

Figure 2 illustrates the overall structure of an event according to a first embodiment of 
the present invention; 

25 Figure 3 illustrates the hardware used in a first embodiment of the present invention; 

Figure 4 illustrates the architecture of the software used in the first embodiment to 

provide a Directory Service (DS); 

Figure 5 illustrates the initialisation of the DS; 

Figure 6 illustrates the loading of data handlers; 
30 Figure 7a illustrates the handling of DSUser events with default data handlers; 

Figure 7b illustrates the handling of DSUser events with special data handlers; 

Figure 8 illustrates the handling of DSConfigurator events. 
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In overview, a first embodiment of the present invention provides a system that allows 
flexible management of data in a distributed environment of heterogeneous data storage 
systems. Flexibility is provided via the use of dynamically-loaded software modules 
under the control of policies. These software modules, known as data handlers, are 
implemented as proxylets. A proxylet is a piece of Java™ code that can be dynamically 
invoked within an Execution Environment for Proxylets (EEP). The EEP is a Java™ virtual 
machine (JVM) and each proxylet runs on its own JVM. A further description of 
proxylets and EEPs can be found in Fry et al.. An Infrastructure for Application Level 
Active Networking, Computer Networks 36 (2000) pp5-20. 

In the present embodiment, an organisation wishing to use multiple, heterogeneous data 
storage systems will create a policy document, referred to as a policy hereinafter. A 
policy allows a user within the organisation to specify the behaviour that they want the 
system to exhibit. Policies are written in accordance with a syntax represented by an 
Extensible Markup Language (XML) Schema. The syntax will now be described. 

The overall structure of a policy is shown in figure 1 . The top level policy specification 
consists of six elements. The creator 107, info 109, sender 111, subject 113, trigger 
115 and actions 117 elements each contain additional elements and are described in 
20 detail below. 

The sender 111 element contains (zero or more) strings identifying the forwarding path 
the policy has taken. The information contained in sender 111 could be used as a 
check that the policy has followed an expected route, or to establish that the policy has 
25 already been received by other parts of the system. This element may be modified 
between creation and receipt of the policy. 

This policy specification is intended to be applicable in an environment where there are 
multiple points of control. Nodes should be able to accept control from users with 
30 different privileges. Since it is desired to achieve control by the use of policies, the 
Creator element 1 07 is provided in order to establish the origin of a policy. 



The creator element 1 07 consists of an authority element 119 which rtself consists of a 
role 121. (A role is simply a name for a group of related members and can be of any 
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size [zero or more members]. An individual system entity can be in one or more roles at 
any time and role membership is not necessarily static.) The creator element 107 
therefore allows the credentials of the policy author to be validated in a generic way, 
simplifying authorisation. It is also important in conflict resolution. Since control of 
5 particular system components may be shared, and policies may be set independently, 
conflicts cannot be prevented. Knowledge of the creators of a number of conflicting 
policies can allow priorities to be set. 

The creator element 107 also includes an identity element 123 which specifies the 
1 0 individual responsible for the policy. 

The Info element 109 contains most of the information about the policy which is not 
directly related to the policy rules. It consists of two elements. The policy-id 1 25 is a 
string intended to be globally unique. The policy-id 1 25 is intended to be automatically 

1 5 processed and allows a policy to be unambiguously referenced. The description element 
127 is an optional text string which is intended primarily for a human reader of the 
policy. It can be used to convey any additional information which is not intended for 
automated processing. The expiry-time 126 indicates when the policy should no longer 
be applied. The replaces element 128 contains a number (zero or more) of references to 

20 policies which are to be removed when the current policy comes into effect. These 
references match the policy-id elements in the policies to be replaced. 

The subject element 1 1 3 identifies those entities in the system which are expected to 
execute the policy and invoke policy actions. Identification of these entities is done by 
25 role 131. This Is important so that a policy can refer to entities which are not present 
or not known at the time of creation. 

The subject element contains a domain element 129 (which is also used to identify 
targets for an action as described below). This allows set expressions to be used to 
30 identify the required group of entities. 

The policy specification presented here is assumed to work with an event-based 
approach to distributing knowledge of system state. In this case a policy specifies the 
behaviour that a component should exhibit when a particular event occurs. The trigger 



wo 03/096221 



PCT/GB03/01973 



9 

element 1 1 5 in the policy relates an event to the policies that are supposed to handle it. 
When an event is detected, relevant policies must be activated. It is assumed that a 
policy is triggered by a single event. The trigger element 115 contains a single event-id 
element 133. This is a globally unique string, similar to the policy-id 125, which 
5 identifies the type of event that has occurred. 

Every policy includes one or more actions elements 117. These specify the behaviour 
that should result from the triggering of the policy. Each actions element contains an 
optional condition element 135. This is an expression which evaluates as either true or 
false. If it is true, the associated action elements (of which there is at least one) are 
processed. If it is false, they are ignored. The condition takes the form of a simple 
logical expression where the operand elements 137,139 identify parameters known to 
the entity evaluating the policy. These may, for example, be contained in the event 
triggering the policy. The operator element 141 allows comparison with other 
parameters or values and include equals, greater and less. 

The action element 143, of which there is at least one in each actions element 117, 
specifies a target 145 set as a domain 147. This has already been discussed in 
connection with the subject element. Once again, target entities are identified by role 
20 149. The data element 151 contains an element specifying the precise nature of the 
behaviour that should result from the triggering of the policy and references to a 
software module which will invoke this behaviour. In alternative embodiments, the data 
element 151 could contain the executable code of the software module which will 
invoke this behaviour. 

25 

As mentioned above, the policy specification presented here is assumed to work with an 
event-based approach to distributing knowledge of system state. An event is a means 
used to trigger some form of behaviour as a reaction to a phenomenon or system state 
change that has occurred. Event documents (referred to as events hereinafter) can be 
30 generated by users or they can be automatically generated by an entity in the system. 
Events are generated in accordance with a syntax represented by an XML Schema. The 
syntax of events will now be described. 

The overall structure of an event is shown in figure 2. 
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The top level event specification consists of seven elements. Each event type has a 
unique event-id 201, a globally unique string which is used to trigger appropriate 
policies. The time element 203 identifies when the specific event occurred while the 
5 optional timetolive element 205 specifies for how long the event is relevant. Use of this 
information can allow certain events to be discarded if not handled in time, limiting 
unnecessary management traffic. The source element 207 identifies where the event 
originated. The sequence element 209 is an integer which is incremented with each 
event produced from a particular source. This can support ordering of events. The 
10 optional information element 211 is a string intended to be read by people rather than 
processed automatically. The data element 21 3 has an open content model and allows 
any well-formed XML to be included. This is where any specific information relevant to 
the event can be included. 

1 5 The policy-based data management system of the present embodiment is now described 
in more detail. 

The first embodiment of the present invention is implemented in a system called 
Directory Service (DS). The DS itself consists of modules that have been written in the 

20 Java™ programming language. The modules are loaded onto a server 301 which is 
connected to a data communications network 304 (such as an IP network) via a first 
notification server 303. Clients 307 are also connected to the communications network 
304 via a second notification server 305. The notification servers handle all 
communications between clients 307 and the DS. Clients 307 needing to send an 

25 event or policy to the DS use the second notification server 305 as an entry point to the 
system. In the present embodiment, Java™ remote method invocation (RMI) is used for 
this interface. (For details of RMI see Merlin Hughes et aL, Java Network Programming, 
Manning Publications, 1997, pSOI.) Also connected to the communications network 
are data stores 309. These data stores could be, for example, file databases, relational 

30 databases or object-oriented databases and could be provided by, for example, IBM, 
Oracle or Sybase. 

Interaction between the clients 307 and the DS 400 occurs through the consumption 
and production of event documents. An event is considered consumed when it is 
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generated at a source and received at the DS 400 and produced when it is generated at 
the DS 400 and received at a different destination. 

The DS 400 accepts event-based interactions from clients belonging to DS-specific 
roles, namely DSUser, DSConfigurator and DSAdministrator, 

Clients which simply use the store and retrieve functionalities of the DS 400 are known 
as DSUsers. A DSUser may send to the DS 400 any of the following events: StoreData 
(in order to store data in one of the data stores 309), StoreEvent (in order to store (i.e. 
log) an event in one of the data stores 309), StoreProxylet (in order to store proxy let 
meta-data) and Query (in order to query some data in one of the data stores 309). The 
DSUser would include the event name in the event-id element 201 of the event and 
either (i) the data or proxylet to store, (ii) the event to log or (iii) the query expression, in 
the data element 21 3 of the event. 

The DS 400 supports default data handling mechanisms for handling requests in case 
no special requirement is imposed by DSUsers. However, there may be DSUsers 
requiring that the DS 400 uses customised data handlers, i.e. data handlers other than 
the default ones. For this to happen the DS 400 needs have been properly configured 
prior to a request arriving. Configuration can be carried out by a DSConfigurator. 

Clients with all the privileges of DSUsers and also the privilege of setting the DS 400 up 
with configuration policies are known as DSConfigurators. A configuration policy 
(DSPoIicy) is a policy that determine the software module that should be used for 
managing incoming content. The name of the DSPoIicy is contained in the policy-id 
element 125 of the DSPoIicy. The name of the event that triggers the DSPoIicy is 
contained in the event-id element 133 of the policy and should match the event-id 
element 201 of the triggering event. Examples of DSPolicies are StoreData, StoreEvent, 
StoreProxylet and Query. 

A DSConfigurator interacts with the DS 400 by sending StoreDSPolicy events (in order 
to store a DSPoIicy) and QueryDSPolicy events (in order to query a DSPoIicy) to the DS 
400. The DSConfigurator would include the event name in the event-id element 201 of 



wo 03/096221 



PCT/GB03/01973 



12 

the event and the DSPolicy to store or query expression in the data element 213 of the 
event. 

Clients with all the privileges of DSConfigurators and also the privilege of creating 
5 administrative policies are known as DSAdministrators. Administrative policies 
determine what software module should be used for managing incoming DSPolicies. 

A further role Is that of the Directory Service. This role directly represents the DS 400. 
It is only used to identify the DS as the subject and target of actions of DSPolicies and 
1 0 the source of QueryResults events (produced by the DS in order to return the results of 
a query; returned in the data element 213 of the event) and Ac/cnow/edgement events 
(produced by the DS in order to confirm the success of an operation. A message 
confirming the success is included in the data element 213 of the event). 

1 5 Referring now to figure 4, the DS 400 consists of the following modules: a Receiver 
403, Policy Handler 405, Event Handler 407, Policy Store 409, DS Adapter 41 1 , Data 
Handlers Registry 413 and two data handlers - a Storage Handler 415 and a Query 
Handler 417. As mentioned above all the modules have been written in the Java™ 
programming language. 

20 

Receiver 403 

This is the principal class that initiates the DS 400 with the main method. When the 
Receiver 403 is run, it firstly Initialises the DS 400. Then, a reference to a Receiver 
object is published to a remote method invocation (RMI) registry so that the notification 

25 server 303 can contact the DS. The Receiver 403 consumes events sent to the DS 400 
by clients 307 and responds by producing Acknowledgement events and QueryResults 
events. Upon consumption of an event a Transaction Context object is created and the 
Event Handler 407 Is contacted. When producing an event, the Receiver 403 uses the 
getEventSourceURIO method (see below) of the transaction context object in order to 

30 retrieve the destination to which the event is to be sent. 

Transaction Context 

This class aims at recording information relevant to every new transaction that starts as 
soon as an event is consumed. The transaction-related information captured in the 
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transaction context object is the event source's name and location. It will be 
remembered that this information is contained in the source element 207 of the event. 
The transaction context object provides getter [getEvenSourceEntityO and 
getEventSourceURIOl and setter methods [setEvenSourceEntityO and 
5 setEventSourceURK)] for this data. The transaction context object is created at the 
Receiver 403, it is updated by the Event Handler 407 and it is consulted by the Receiver 
403 and Policy Handler 405. It is an object exchanged between Receiver 403, Event 
Handler 407 and Policy Handler 405 in order to provide to all a common view of useful 
transaction-related information. 

10 

Event Handler 407 

This class is responsible for handling all consumed DS events. It contains the 
handleEventO method and getDSPolicyO method. The event XML document and a 
transaction context object are passed to the handleEventO method by the Receiver 403. 

15 The handleEventO method firstly parses the event XML document to generate a 
document object model (DOM) tree and then unwraps the data part from the rest of the 
event DOM, where data represents the content to process i.e. the information to store 
or query to run. It will be remembered that the data is contained in the data element 
213 of the event. Additional processing involves updating the transaction context 

20 object with event source name and location. It will be remembered that this information 
is contained in the source element 207 of the event. The getDSPolicyO method 
retrieves from the Policy Store 409 the relevant policy based on the event-id found in 
the event-id element 201 of the event and the event-id element 133 of the policy. In 
case no policies are found, the DS Adapter 41 1 is directly contacted for handling of the 

25 data using the default data handlers. If the consumed event involves storing a 
DSPolicy, then the getDSPolicyO method retrieves an administrative policy. All retrieved 
policies are parsed before being passed onto the Policy Handler 405. 

Policv Handler 405 

30 This class handles the retrieved DSPolicies. It contains the following methods: 
handlePolicyO# validatePolicyO, analysePolicyO and executeActionO. The Event Handler 
407 passes the retrieved policy to the handlePolicyO method. The Policy Handler uses 
the validatePolicyO method to check the validity of the policy. The following rules must 
be satisfied by the policy elements: 
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i. The value of the role element 121 needs to indicate a role with the privilege of 
performing the specified actions. 

ii. The value of the identity element 123 needs to match the value of the source 
5 element 207 of the event. This association assumes that the policy creator is 

the same entity as the event source. 

iii. The value in the policy-id element 205 should contain the policy name which 
matches the name of the triggering event. 

iv. The value in the role element 131 should mention the Director/Service role 
10 because this is the subject that executes the policy and invokes policy actions. 

V. The value in the event-id element 133 should match the event-id element 201 of 
the corresponding event that triggers the policy. 

vi. The value in the operand element 1 37 should be set to EventSource by default. 

vii. The value in the operator element 141 should be set to equals by default. 

15 viii. The value in the operand element 139 should be set to the same value as the 
identity element 1 23 and the source element 207 of the event 
This and rules (vi) and (vii) above impose a condition which indicates that in 
order to trigger the policy, apart from checking the event type, it is also 
necessary to check if this event is originating from a trusted source. This is 
20 important as consumed events with the same event-id, such as StoreProxylet, 

may be generated by more than one source but the specific policy should only be 
triggered when this one event comes from one specific source, 
ix. The value in the role element 149 should specify the DirectoryService role as this 
is the target on which to invoke the particular policy action. Specifically, the 
25 target on which to invoke the action is the DS Adapter but this is an internal DS 

mechanism and not a role. 
X. The value in the data element 151 should include the name of the proxylet class, 
the location of the jar file containing the proxylet code (a jar (Java™ Archive) file 
is a compressed archive that contains the proxylet code as well as any other 
30 relevant code associated with the proxylet, i.e. any other class the proxylet 

needs to have in each class path in order to run with no errors) and one of two 
'method' values, namely, store or query for store or query events respectively. 
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Next, the analysePolicyO method interprets the policy to recover details about which 
data handler proxylet to use. These details (the name of the proxylet class and the 
location of the jar file containing the proxylet code) are the values contained in the data 
element 151. The recovered details and the data found in the data element 213 of the 
5 event are used by the executeActionO method which then communicates with the DS 
Adapter 41 1 . In case the chosen policy is an administrative one, analysePolicyO will 
target the content, represented by the data found in the data element 213 of the event, 
to the Policy Store 409, 

10 Policv Store 409 

This is an internal database that stores configuration and administrative policies. The 
present embodiment uses XSet, an in-memory and XML-based database. In-memory 
databases are a special type of database in which all data Is stored in memory instead 
of in files on a hard disk in order to provide faster access to the data. Details of XSet 

1 5 can be found in The XSet XML Search Engine and XBench XML Query Benchmarkr 
Technical Report UCB/CSD-OO-1 1 12, Ben Yanbin Zhao, Computer Science Division, 
University of California, Berkeley, 2000. The Policy Store 209 provides access methods 
to its content. Specifically, storelnXSetO stores XML documents either in the form of 
DOM trees or read in from files and queryXSetO retrieves XML documents by executing 

20 a query expression. 

DS Adapter 411 

This class is responsible for loading and managing data handlers and for the invocation 
of policy actions. The Policy Handler 405 passes to the invokeActionO method of the 

25 DS Adapter 41 1 class the name of the proxylet class, the location of the jar file 
containing the proxylet code and the name of the action to invoke. These three values 
are all contained in the data element 151 of the policy. Then the DS Adapter 411 
checks the Data Handlers Registry 413 for the handler's availability and in case of 
failure the loadHandlerO method of the DS Adapter class is used to initiate the handler's 

30 proxylet passing to the registry the proxylet' s name and location. The proxylet starts 
running in the EEP and a reference to the handler is recorded in the registry using the 
registerHandlerO method of the DS Adapter class. The invokeActionO method is also 
used by the Event Handler 407 in case no policies are retrieved and the default data 
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handlers need be used. The Receiver 403 also uses the invoke ActionO method during 
initialisation in order to start the default data handlers. 

Data Handlers Reqistrv 41 3 

This is a local table that keeps references to the already initiated data handlers, which 
are registered to it by inserting the data handler proxylet's name into the table. Access 
methods are provided namely, putO for store, getO for retrieval, removeO for delete and 
containsHandlerO for checking the inclusion of a data handler reference. Each member 
of the registry implements the following Java interface, which is just a marker i.e. it 
only marks each member as a Data Handler. 

public interface DataHandler {} 

The only module that contacts the Data Handlers Registry 41 3 is the DS Adapter 41 1 . 
15 

Data Handler Proxvlets 

The role of the Data Handler Proxylet is to control the lifetime of a data handler. More 
specifically, it can initialise, run, control and stop a Data Handler through the respective 
methods of the proxylet interface. 

20 

In the initO method, the address for an rmi registry is received and stored locally. This 
address is important information for the proxylet, as this is where it will publish the data 
handler reference. The address is written as an external argument next to the name of 
the proxylet in the Launcher.runO method called in the DS Adapter 41 1 . 

25 

In the runO method the aim is to create a data handler object and publish it to the 
specified rmi registry address. The name used to publish the handler is the name of the 
current proxylet. The main reason for this is the intention to control the handler entirely 
through the proxylet, hence every access to the rmi registry in search of the handler 
30 retrieves its associated proxylet's name. In order that the EEP does not automatically 
call the stopO method killing the proxylet, the run{) method enters an indefinite while 
(true) loop so that control of killing the proxylet and hence the handler is obtained from 
outside, specifically from the Launcher.stopO method. In order to minimise the resource 
consumption by the proxylet while it remains alive, the while(true) loop contains a 
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Thread. currentThread0.sleep( 10000) statement that puts the current thread to sleep for 
10 sees. 

Finally the stopO method includes code that removes the data handler reference from 
5 the rmi registry. This completes the proxylet's control of the lifetime of the handler. 

File Storage Handler 215 

This module stores XML documents in files. In the present embodiment there is only one 
file created to keep ail the received data. In alternative embodiments it is possible to 
10 create one file per role to achieve separation of content. The handler Implements the 
following StorageHandler interface 

public interface StorageHandler extends DataHandler, Remote{ 
public void store (String xmlString) throws RemoteException;} 

15 

The storeO method receives a string that represents the XML document to save. Every 
storage handler needs to implement this interface. StorageHandler also extends 
Remote. This means that contact with the handler is achieved through RML The 
respective handler proxylet takes care of publishing a handler object to some rmi 
20 registry. The real handler object is contacted directly by the DS Adapter 41 1 . 

File Query Handler 417 

This module implements the querying functionality to retrieve XML documents from 
files. The targeted file is the same as that used by the FileStorageHandler to store XML 
25 documents. The handler implements the following QueryHandler interface 

public interface QueryHandler extends DataHandler, Remote{ 

/A/ector contains Strings each representing one XML document that is a query hit. 
public Vector query(String xmlString) throws RemoteException; 
30 }//End interface 

The queryO method receives a string that represents the query expression. QueryO 
executes the expression and retums a vector containing the results in the form of 
strings, i.e. each string corresponds to a XML document. Generally, every query 
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handler needs to implement this interface. QueryHandler also extends Remote. This 
means that contact with the handler is achieved through RMI, The respective handler 
proxylet takes care of publishing a handler object to some rmi registry. The real handler 
object is contacted directly by the DS Adapter 411. 

5 

When a DS instance is started, the DS 400 initially registers with a notification server 
program 401, which has been loaded onto the notification server 303, to announce its 
Interest in listening for certain types of event specific to the DS 400. Each time a client 
307 has to send to the DS 400 either a query or data for storage, it issues an event 

10 with the query expression or data for storage contained in the data element 213. The 
event firstly reaches a notification server program 402, which has been loaded onto the 
notification server 305 and which the client 307 is registered with. Upon reception of 
the event, the notification server program 402 wraps the event up in a notification 
message 419 (i.e. the event is enclosed within the notification message 419) and 

15 delivers the message to the notification server program 401 that the DS 400 is 
registered with. The notification server program 401 unwraps the event part from the 
message (i.e. extracts it) and sends it to the Receiver 203. 

Referring to figure 5, initially the Receiver 403 consumes two events (501). These 
20 events are sent by a client 307 acting in the role of a DSAdminlstrator. The events 
contain in their data elements 213 two administrative policies. The event-id elements 
133 of both policies do not contain any values, indicating that the policy Is to be 
activated as soon as it is received. The first policy determines that upon consumption 
of a StoreDSPolicy event, sent by a DSConfigurator role, the data contained in the data 
25 element 213 of that StoreDSPolicy event should be stored in the Policy Store 409. The 
second policy indicates that when a QueryDSPolicy event is consumed, the query 
contained in the data element 213 of that QueryDSPolicy event should be run on the 
contents of the Policy Store 409. Both administrative policies are stored (503) in the 
Policy Store 209. 

30 

Then the Receiver initiates (505) two default data handlers, one for storing and one for 
querying. The default handlers are used any time StoreEvent, StoreProxylet and Query 
events arrive from a DSUser and no DSPolicy is found in the Policy Store 409 to 
indicate how to handle these events. The default handlers are an Instance of a 
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FileStorageHandler and a FileQueryHandler which both manipulate content in files. The 
handler loading process is thoroughly described below. 

The loading and running of data handlers by the Directory Service will now be described 
5 with reference to figure 6. 

The main module that handles the process is the DS Adapter 41 1 . Each request (601) 
arriving at it carries information about what proxylet to load. This information consists 
of the name of the proxylet to load and of the URL for the location of the jar file 
10 containing the proxylet code. The DS Adapter 41 1 uses the name of the proxylet firstly 
to check (603) in the Data Handlers Registry whether the proxylet is already loaded and 
running. If the data handler proxylet is running then it is returned (605/607) as an 
object to the requesting entity. If the proxylet is not yet running then the DS Adapter 
41 1 uses a Proxylet Launcher object 414 to start it. The Proxylet Launcher object 414 
15 is a singleton, i.e. it is instantiated once within the DS Adapter 41 1 and is active all the 
time the DS Adapter 41 1 object is alive. Upon instantiation of the Proxylet Launcher 
414, information is passed to it about what host runs the EEP which executes the data 
handler proxylets. Then the Proxylet Launcher is instructed by the DS Adapter (609) to 
load (61 1) the proxylet jar file from the indicated location. Finally the Proxylet Launcher 
20 414 is instructed (613) to run (615) the proxylet with the particular name. The proxylet 
is then returned as an object (617) to the requesting entity. During execution of the 
runO method of the proxylet, an instance is created (619) of the data handler controlled 
by the proxylet and it is published (621) to an rmi registry so that the data handler 
instance can be remotely contacted. The location of the host running the rmi registry is 
25 passed along with the name of the proxylet within the String argument of the 
Launcher's run() method. To keep the proxylet alive as long as the handler object is 
alive, the proxylet's runO method enters an indefinite loop. Otherwise the proxylet 
would stop and control over the Data Handler object would have been lost. The final 
remaining step for the DS Adapter is to update (623) the Data Handlers Registry 413 
30 with the new Data Handler object, using the name of the handler controlling proxylet as 
an identifier of the handler within the registry. 

The handling of DSUser events using the default data handlers will now be described 
with reference to figure 7a. 
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The Receiver 403 consumes (701) StoreProxylet, StoreEvent and Query events arriving 
at it from a client through notification servers 303/305. The event is parsed (703) 
using the Xerces Java™ Parser (from The Apache XML Project) and a Transaction 
5 Context object is created (705). Both event and transaction context object are passed 
(707) through to the Event Handier 407, which initially unwraps (709) the data from the 
event. The data represents either the content to store in or a query to execute and is 
contained in the data element 213 of the event. Additionally, the Event Handler 407 
updates the Transaction Context object with the event-Id and the event originator's 
10 URL, information indicated by the value of the source element 207 of the event. Next, 
the Policy Store 409 is contacted (71 1) to retrieve any policies relevant to the received 
event. Important information for this search is the event-id contained in the event-id 
element 201 of the event. In this current case the assumption is that no such policies 
have been set by a DSConfigurator role prior to the event's occurrence, hence the 
15 search yields no policies (713). Therefore, the Event Handler 407 assigns the Default 
Data Handlers to handling the received data, so it interacts (715) with the DS Adapter 
41 1 to obtain the active instance of either the default Storage Handler or the default 
Query Handler. Since the default handlers are initiated at the moment of the Directory 
Service initiation (see above), they are already registered in the Data Handlers Registry 
20 413; hence the DS Adapter 411 immediately retrieves and returns the appropriate 
handler reference (717). The Event Handler 407 consults a list of events consumed by 
the DS 400 and decides what action to involve on the retrieved data handler, based on 
the received event-id. Next, the action is invoked (719) on the data handler. In case of 
a query, the Receiver 403 produces a QueryResults event (721) that contains the 
25 results returned (723) to it from the Event Handler 407. In case of a storing action, an 
Aclcnowledgement event is produced (719). Either produced event is finally returned 
(725) to the requesting client through the notification servers 303/305. The event's 
destination is obtained from the Transaction Context object. 

30 The handling of DSUser events with data handlers that are dynamically initiated upon 
the consultation of a DSPolicy will now be described with reference to figure 7b. 

This case follows the same sequence of operations (701-711) as above until the point 
where the Event Handler 407 contacts the Policy Store 409. This time the search 
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yields a DSPolicy (727), which is passed (729) to the Policy Handler 409 along with the 
data contained in the data element 213 of the event and the Transaction Context 
object. The validation process (731) concentrates upon checking the values of certain 
elements in the policy document. A valid policy is one that is created by a 
5 DSAdministrator or a DSConfigurator role. In the latter case specifically, it is 
additionally required that the entity which created the policy is the same as the entity 
that sends the DSUser event. Practically, this requires the value of the source element 
207 of the event to be equal to the value of the identity element 1 23 of the policy. The 
next step is to analyse (731), i.e. interpret, the policy. The aim of the analysis is to 
10 extract the information that describes the Data Handler which should be used. The 
specific information is the name of the data handler proxylet class, the location of the 
proxylet's jar file and the name of the method to invoke on the handler. This 
information is contained in the data element 151 of the policy. Subsequently, the 
proxylet name and jar file location are passed (733) onto the DS Adapter 41 1 module 
1 5 with the request to run the specified handler. The process followed here is the same as 
that described above. When the Data Handler is run, the Policy Handler 405 requests 
(735) that the DS Adapter 41 1 invokes the action specified in the selected DSPolicy, 
passing also the data (from data element 213) to be handled. The DS Adapter 411 
invokes the requested action and returns (737) either query results or a success/failure 
20 indication of the storing operation. This return is propagated (739) all the way back to 
the Receiver 403 which respectively produces (741) a QueryResults or 
Acknowledgement event to send back (743) to the initial event source through the 
notification servers 303/305. 

25 The handling of DSConfigurator events (e.g. StoreDSPolicy and QueryDSPolicy events) 
will now be described with reference to figure 8. 

In the beginning the event is consumed (801) by the Receiver 403. Then it gets parsed 
(803) and a Transaction Context object is created (805). Both parsed event and 
30 transaction context object are sent (807) to the Event Handler 407 which unwraps 
(809) the data, contained in the data element 213, from the event and updates the 
transaction context object with the event source URI from the source element 207 of 
the event. Next, the Policy Store 409 is checked (811) for administrative policies. 
These policies are created by the DSAdministrator role and are the ones that the DS 
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read in from files as described above. These policies determine tliat the Policy Store 
409 is the data store to target when handling the content of DSConfigurator events. 
The retrieved administrative policy is returned (813) to the Event Handler 407 and then 
passed (815) along with the data to the Policy Handler 405. There, the policy is 
5 validated and analysed (817) after which the Policy Handler 405 invokes (819) the 
action specified in the policy to either store or retrieve content from the Policy Store 
409. The Policy Store 409 then returns (821) either query results or a success/failure 
indication of the operation. The results are propagated back (823) to the Receiver 403 
which produces (825) an Acknowledgement or QueryResults event. Either produced 
10 event is finally returned (827) to the initial event source through the notification servers 
303/305. 

An extension to the above described embodiment allows a client to set policies with a 
scope of one transaction that the client may hold with the DS 400. In this case the 
1 5 policy would describe a specific data handling requirement for the current client request. 
This type of policy is called a data handling policy. For example, a user runs a query 
from a personal digital assistant (PDA) and wants the presentation of the query results 
to be adjusted to a customary format compliant with the PDA. For this purpose the 
client may send along with the query a policy that captures this particular requirement, 
20 i.e. the fact that the results are expected in a presentation format compliant with Ms 
PDA. A corresponding configuration policy may already exist in the DS 400, prior to the 
initiation of the query transaction by the client and may contain information about a 
format-adjusting proxylet. This proxylet should contain code that implements the 
necessary format transformation taking account of all special features specifically 
25 characterising the client's PDA. In this sense the configuration policy, which represents 
all knowledge about the transformation into the PDA-compliant format, may be 
continuously resident in the Policy Store 409 for longer than the query transaction's 
lifetime, even longer than the time the user is active on the PDA, and it may be 
executed in many other transactions between the client and the DS 400. On the other 
30 hand, the data handling policy is active within the boundaries of only one transaction. 
In the example, when the query results are retrieved at the DS 400, the Policy Handler 
405 handles the data handling policy. The above explained DSPolicy then has to be 
retrieved from the Policy Store 409. It includes details of the proxylet to run in order to 
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achieve the format transformation. It is important that the data handling policy follows 
the same rules as a DSPolicy so that it can be validated by the Policy Handler 405. 

Although in the above described embodiment the clients 307 communicated with the 
5 DS 400 via notification servers 303/305, in other embodiments a direct client/server 
link across the communications network 304 is possible. 

Although in the above described embodiment an in-memory based database (XSet) was 
used as the Policy Store 409, in other embodiments any persistent data store such as 
10 those available from IBM, Oracle and Sybase would be suitable. Furthermore the Policy 
Store 409 could be remote from the DS 400, e.g. linked via the communications 
network 304. 

« 

Although in the above described embodiment the data handlers were described to be 
15 part of the DS 400, in other embodiments they could be remote from the DS 400, e.g. 
linked via the communications network 304. 

Although in the above described embodiment the DS is implemented to host only store 
and query policies and respond only to store and query events, other types of policy and 
20 event are possible. For example, update events would occur when a DSUser needs to 
update already stored proxylet meta-data and delete events would occur when a DSUser 
needs to delete a proxylet or a policy. 

The main benefit of the DS stems from the fact that it is configurable from the client's 
25 viewpoint with policies that are interpretable by the DS and which reflect the client's 
requirements. This configurability is in addition to configuring the DS with 
administrative policies that drive its internal behaviour. The example given below of an 
application of the DS is indicative and not exhaustive: 

30 An organisation's Intellectual Property Department (IPD) wants to create a list of all the 
inventions that have arisen out of each of the organisation's laboratories in the last 10 
years. This would require access to IPD's own internal records database (in order to 
find the inventors' names and the case file number) and also to the organisation's 
personnel database (to find the inventor's Organisation Unit Code (OUC), i.e. which 
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laboratory that inventor works in). IPD would have to run its own database's client 
program to get the inventors' names and case file numbers and a web browser program 
to get the corresponding OUCs. 

5 To integrate the two databases, IPD could implement a Mediator based approach, an 
FDBMS based approach or it could achieve the integration by providing a policy and 
appropriate data handlers for the DS. In other words, the functionality of a mediator or 
an FDBMS may be provided by a policy and a set of data handlers. A description of 
what the relevant policy and the data handlers would do to provide this functionality is 
10 given below. 



EVENT 

A message from IPD arrives at the DS requesting a list of all the inventions that have 
arisen out of each of laboratory in the last 10 years. The DS searches in the policy 
1 5 store for relevant policies. The search yields a policy 1 below. 



P0LICY1 

Action 1 : Activate and run a proxylet that returns all inventor names and case file 
numbers for the past 10 years In a structure containing the fields ''Name 
20 of Employee" and "Case File Number". This proxylet runs a query 

against the IPD internal records database. 
Action2: Activate and run a proxylet that returns all the OUCs for the names 
retrieved by Action 1 in a structure containing the fields "Name of 
Employee" and "OUC. This proxylet runs a query on the organisation's 
25 personnel database. 

Conditions: If, because some employees are associated with more than one invention, 
there are records appearing more than once in the structure returned by 
Action2 then do Actions. 
Actions: Activate and run a proxylet that retrieves the structure returned by 
30 Action2 and returns a structure containing distinct records, i.e. it leaves 

out duplicate records. 

Condition4: If the structure returned from Actioni and Action4 are not the same (e.g. 

Action 1 returns the result in a Java vector and Action4 in a Java Array) 
then do Actions. 
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25 

ActionB: Activate and run a proxy let that transfornns the results from the above 
data structures (i.e. those returned in Action 1 and Action4) into a 
common data structure (e.g. a Java vector). 

Action6: Activate and run a proxylet that joins together the structures returned 
from Actions. Return a new structure (e.g. a Java Vector) containing the 
fields "Name of Employee, OUC, Case File Number". 

Action?: The DS generates an event called ResultsObtained that contains the 
results of Action? expressed in XML. Based on this event the DS 
searches the policy store and retrieves a set of relevant policies (Policy2 
and PolicyS below). These policies determine how the results are to be 
presented to the user who initially sent the query. 



P0LICY2 

Conditioni : If the enquiry is from a client in IPD... 

15 Action 1: Activate and run a proxylet that unwraps the data from the 
ResultsObtained event, produces a new structure (e.g. a java vector) 
containing the OUC and the case file numbers associated with each OUC 
(in this structure, each OUC will appear only once and each OUC will have 
associated with it one or more case file numbers) and populates the 

20 graphical user interface (GUI) at the client side with a table showing the 

results in two columns, one containing the OUC and one containing the 
associated case file numbers. 



POLICYS 

25 Conditioni : If the enquiry is from a client in OUC ABC1 23... 

Actioni: Activate and run a proxylet that unwraps the data from the 
ResultsObtained event, selects records containing the OUC ''ABC123'', 
produces a new structure (e.g. a java vector) containing the fields ''Name 
of Employee" and "Case File Number" and populates ABC123's web page 

30 with a table showing the results in two columns. 



The DS decides whether to execute P0LICY2 or POLICYS based on the user who sent 
the query. 
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The benefit of using the DS over a Mediator or FDBMS based approach is that all the 
processing requirements are declared through a policy and the processing is executed by 
pieces of code (i.e. proxylets) that are dynamically invoked on demand. 

5 A Mediator based approach would implement explicitly all the rules of the described 
policy. That is to say the policy rules would have the form of a program which actually 
constitutes the Mediator's implementation. Every time a slight change to the rules is 
necessary, this would mean having to change the Mediator's implementation (i.e. amend 
the program code, recompile it and redeploy it) or having to implement a new mediator 
10 that inherits the characteristics of the old one and provides the additional specific 
changes. This would result m complex interrelationships between Mediators and lead 
eventually to a very complex and highly coupled Mediator infrastructure. For the DS, 
changing the rules only means changing the XML specification of the policy, i.e. 
changing the current policy or creating a new policy. Hence, the DS Is more flexible 

15 than a Mediator based approach. 

An FDBMS based approach would have had to firstly produce a new. Integrated schema 
from both the data schemata of IPD's internal records database and the data schemata 
of the organisation's personnel database. Only then could the whole query be run. 
20 Using the DS, the integration is achieved by implementing the described policy In the DS 
and hence there is no requirement to carry out a physical integration of the data. 
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CLAIMS 

1 . A method of operating a computer system to provide a user interface to a data 
storage system, said computer system including a rule store storing one or more rules, 
said method comprising the steps: 

providing a user interface to said rule store enabling user configuration of said 
rule store with one or more rules, each rule including information relating to a handler 
program, said handler program being associated with one or more user requirements and 
being operable to interact with said data storage system in accordance with said user 
requirements; 

receiving a request detailing one or more user requirements; 
responsive to receipt of said request: 

a) searching said rule store for a rule associating said one or more 
user requirements of said received request with a handler program; 

b) running said handler program to interact with said data storage 
system. 

2. A method according to claim 1, wherein said information relating to a handler 
program comprises the name and the location of the handler program. 

3. A method according to claim 1, wherein said information relating to a handler 
program comprises the handler program itself. 

4. A method according to any of claims 1 to 3 further comprising the step of 
running a default handler program to interact with said data storage system if no rule 
associating a handler program with the one or more user requirements of said received 
request is found. 

5. A method according to any of claims 1 to 4, wherein said rule store user 
interface provision step comprises storing a rule associating predetermined user 
requirements with a handler program executable to interact with said rule store to 
introduce a further rule contained within said request into said rule store. 
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6. A method according to claim 5 wherein said further rule replaces an existing 
rule. 

7. A method according to claim any of claims 1 to 4 wherein said request 
comprises a request to store a handler program. 

8. A method according to claim 7 wherein said further handler program comprises 
a default handler program. 

9. A method according to claim 1 wherein said request contains a rule associating 
a handler program with the user requirements of said received request. 

10. A method according to any preceding claim wherein said rules are expressed in 
the form of text. 

11. A method according to claim 1 0 wherein said rules are preparable using a text 
editor. 

12. A method according to any preceding claim wherein said rules are indicative of 
a time after which said rules should no longer be applied. 

13. A method according to any preceding claim wherein said data storage system 
comprises a plurality of databases. 

14. A method according to claim 13 wherein said databases are of a different 
format to each other. 

15. A method according to any preceding claim wherein said rule store user 
interface is restricted to a certain class of user. 

16. A method according to any preceding claim wherein the data storage system 
user interface is available to a different set of users from those able to modify said rules 
in said rule store. 
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17. A method according to any preceding claim wherein said computer system 
comprises a plurality of computers in communication with one another, the handler 
programs being run on a different computer to the one that receives said request. 

5 18. A method according to any preceding claim wherein said computer system 
comprises a plurality of computers in communication with one another, the rule store 
being on a different computer to the one that receives said request. 

19. A computer system operable to provide a user interface to a data storage 
1 0 system, said computer system comprising: 
a data storage system; 
a rule store; 

a user interface to said rule store operable to enable a user to configure said 

rule store with one or more rules, wherein each rule includes information relating to a 
15 handler program, said handler program being associated with one or more user 

requirements and being operable to interact with said data storage system in accordance 

with said user requirements; 

request receiving means arranged in operation to receive a request detailing one 

or more user requirements; 
20 rule store searching means operable to search said rule store for a rule 

associating said one or more user requirements of said received request with a handler 

program; 

handler program running means operable to run said handler program to interact 
with said data storage system. 

25 

20. A digital data carrier carrying a program of instructions executable by 
processing apparatus to perform the method steps as set out in any one of claims 1 to 
18. 

30 21. A method of operating a computer system to provide a user interface to a data 
storage system, said computer system including a rule store storing one or more rules, 
each rule associating a handler program with one or more request characteristics, said 
method comprising: 
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providing a user interface to said rule store enabling the modification of said rules 
in said rule store; 

receiving a request having one or more request characteristics; 
responsive to the receipt of said request: 

a) finding a rule in said rule store associating a handler program with 
the one or more characteristics of said received request; and 

b) running said handler program to interact with said data storage 
system. 

22. A method according to claim 21 further comprising the antecedent step of 
storing one or more rules in said rule store. 

23. A computer system for providing a user interface to a data storage system said 
computer system comprising: 

a data storage system; 

storing means arranged in operation to store one or more rules, each rule 
associating a handler program with one or more request characteristics; 

means arranged in operation to provide a user interface to said rule store 
enabling the modification of said rules in said rule store; 

receiving means arranged in operation to receive a request having one or more 
request characteristics: 

finding means arranged in operation to find a rule in said rule store associating a 
handler program with the one or more characteristics of said received request; and 

running means arranged in operation to run said handler program to interact 
with said data storage system. 
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